Dynomotion

Group: DynoMotion Message: 8423 From: Hugh Sontag Date: 10/1/2013
Subject: Homing with BLDC motors
Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh

Group: DynoMotion Message: 8425 From: TK Date: 10/1/2013
Subject: Re: Homing with BLDC motors
Hi Hugh,

All good questions. Yes the commutation is based on the Encoder Position so arbitrarily changing the position. The Zero() command should zero the Position and the Destination and automatically adjust the commutation offset to keep the commutation the same. 

There are many possible strategies to homing slaved axes.  Probably the best is to jog both through the indexes and capture where they are. The stop both. Then move both to where they were detected. Then Zero both. Then Slave them together. 

HTH
Regards

TK

On Oct 1, 2013, at 12:39 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh

Group: DynoMotion Message: 8428 From: Hugh Sontag Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Aha! The Zero() function changes the commutation offset!

Thanks for the suggestions.

Hugh


On Tue, Oct 1, 2013 at 6:04 PM, TK <tk@...> wrote:
 

Hi Hugh,

All good questions. Yes the commutation is based on the Encoder Position so arbitrarily changing the position. The Zero() command should zero the Position and the Destination and automatically adjust the commutation offset to keep the commutation the same. 

There are many possible strategies to homing slaved axes.  Probably the best is to jog both through the indexes and capture where they are. The stop both. Then move both to where they were detected. Then Zero both. Then Slave them together. 

HTH
Regards

TK

On Oct 1, 2013, at 12:39 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh


Group: DynoMotion Message: 8434 From: Hugh Sontag Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Hi Tom,

I tried to reverse the direction of my Y axis, but it was not successful.

I ran a version of "AutoPhaseFind" (attached), using an InputGain0 = -1, which got this report:

REPORT FOR Y AXIS
----------------
0 Position =  16384 PhaseAngle = 7.988000
1 Position =  24576 PhaseAngle = 11.993000
2 Position =      0 PhaseAngle = -0.116000
3 Position = -16385 PhaseAngle = -8.112000
Counts per rev =   8192
Counts per cycle =   2045
Counts per cycle (not rounded)=   2045
invDistPerCycle (not rounded)=  0.000488891602
mid =      1
Commutation offset =   2431
Input Gain Specified = -1.000

When InputGain0 is = 1, the Commutation Offset is = -1422.

Then I use "HomeBrushless_Y_Axis_V2.c" to re-find the index, set the axis parameters, and enable the axis. It makes a "bump" sound, and then I hear the clacking sound, which I take to mean that the SnapAmp is faulting. By the way, is there more information on why the fault occurred, and can I find information in the KMotion user interface that tells me the SnapAmp is faulted?

Previously, I have successfully run  "HomeBrushless_Y_Axis_V2.c" with an InputGain0 = 1 and the axis moves successfully, except it moves in the negative direction for positive moves.

Do you have any suggestions on how to make this work?

Thanks,
Hugh


On Tue, Oct 1, 2013 at 6:04 PM, TK <tk@...> wrote:
 

Hi Hugh,

All good questions. Yes the commutation is based on the Encoder Position so arbitrarily changing the position. The Zero() command should zero the Position and the Destination and automatically adjust the commutation offset to keep the commutation the same. 

There are many possible strategies to homing slaved axes.  Probably the best is to jog both through the indexes and capture where they are. The stop both. Then move both to where they were detected. Then Zero both. Then Slave them together. 

HTH
Regards

TK

On Oct 1, 2013, at 12:39 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh


  @@attachment@@
Group: DynoMotion Message: 8436 From: TK Date: 10/2/2013
Subject: Re: Homing with BLDC motors [2 Attachments]
Hi Hugh,

It looks like AutoPhaseFind.c is not reliably detecting the index pulse. The positions reported in the table should always be one rev apart. I thought we discussed this before and made a "fast" Auto phase find. 

But anyways if you take the Commutation offset that worked before you reversed the encoder and add or subtract a half cycle (1024) that should work. So try -398

Overcurrent and over temp are the only reasons for a SnapAmp fault. Over temp can't happen instantly so assume over current caused the fault. 

Regards
TK

On Oct 2, 2013, at 12:38 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I tried to reverse the direction of my Y axis, but it was not successful.

I ran a version of "AutoPhaseFind" (attached), using an InputGain0 = -1, which got this report:

REPORT FOR Y AXIS
----------------
0 Position =  16384 PhaseAngle = 7.988000
1 Position =  24576 PhaseAngle = 11.993000
2 Position =      0 PhaseAngle = -0.116000
3 Position = -16385 PhaseAngle = -8.112000
Counts per rev =   8192
Counts per cycle =   2045
Counts per cycle (not rounded)=   2045
invDistPerCycle (not rounded)=  0.000488891602
mid =      1
Commutation offset =   2431
Input Gain Specified = -1.000

When InputGain0 is = 1, the Commutation Offset is = -1422.

Then I use "HomeBrushless_Y_Axis_V2.c" to re-find the index, set the axis parameters, and enable the axis. It makes a "bump" sound, and then I hear the clacking sound, which I take to mean that the SnapAmp is faulting. By the way, is there more information on why the fault occurred, and can I find information in the KMotion user interface that tells me the SnapAmp is faulted?

Previously, I have successfully run  "HomeBrushless_Y_Axis_V2.c" with an InputGain0 = 1 and the axis moves successfully, except it moves in the negative direction for positive moves.

Do you have any suggestions on how to make this work?

Thanks,
Hugh


On Tue, Oct 1, 2013 at 6:04 PM, TK <tk@...> wrote:
 

Hi Hugh,

All good questions. Yes the commutation is based on the Encoder Position so arbitrarily changing the position. The Zero() command should zero the Position and the Destination and automatically adjust the commutation offset to keep the commutation the same. 

There are many possible strategies to homing slaved axes.  Probably the best is to jog both through the indexes and capture where they are. The stop both. Then move both to where they were detected. Then Zero both. Then Slave them together. 

HTH
Regards

TK

On Oct 1, 2013, at 12:39 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh


Group: DynoMotion Message: 8440 From: Hugh Sontag Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Hi Tom,

I used the "AutoPhaseFind.c" example program to find the commutation offset with the BLDC motors not connected to the mechanics. It seemed to give consistent results.

You provided a "fast" index finding algorithm called "HomeBrushlessSnap3_V2.c", but I wasn't aware of the "AutoPhaseFindFast.c" example program. We did not discuss it before.

When I tried finding the commutation offset using "AutoPhaseFind.c", I disconnected the motor from the mechanics again. The program may not be finding the commutation offset correctly, but multiple runs gives very similar results, within +- 10 out of 2048 counts per revolution.

I tried the commutation offset of -398. Although the Y axis seems to servo OK (I can't change its position by pushing or pulling on it), when I try running a Step Response plot, I get the SnapAmp fault.

I've attached screen shots of the Step Response for both InputGain0 = 1 and -1 (it's successful for an InputGain0 = 1), and the step response data.

Hugh



On Wed, Oct 2, 2013 at 3:43 PM, TK <tk@...> wrote:
 

Hi Hugh,

It looks like AutoPhaseFind.c is not reliably detecting the index pulse. The positions reported in the table should always be one rev apart. I thought we discussed this before and made a "fast" Auto phase find. 

But anyways if you take the Commutation offset that worked before you reversed the encoder and add or subtract a half cycle (1024) that should work. So try -398

Overcurrent and over temp are the only reasons for a SnapAmp fault. Over temp can't happen instantly so assume over current caused the fault. 

Regards
TK

On Oct 2, 2013, at 12:38 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I tried to reverse the direction of my Y axis, but it was not successful.

I ran a version of "AutoPhaseFind" (attached), using an InputGain0 = -1, which got this report:

REPORT FOR Y AXIS
----------------
0 Position =  16384 PhaseAngle = 7.988000
1 Position =  24576 PhaseAngle = 11.993000
2 Position =      0 PhaseAngle = -0.116000
3 Position = -16385 PhaseAngle = -8.112000
Counts per rev =   8192
Counts per cycle =   2045
Counts per cycle (not rounded)=   2045
invDistPerCycle (not rounded)=  0.000488891602
mid =      1
Commutation offset =   2431
Input Gain Specified = -1.000

When InputGain0 is = 1, the Commutation Offset is = -1422.

Then I use "HomeBrushless_Y_Axis_V2.c" to re-find the index, set the axis parameters, and enable the axis. It makes a "bump" sound, and then I hear the clacking sound, which I take to mean that the SnapAmp is faulting. By the way, is there more information on why the fault occurred, and can I find information in the KMotion user interface that tells me the SnapAmp is faulted?

Previously, I have successfully run  "HomeBrushless_Y_Axis_V2.c" with an InputGain0 = 1 and the axis moves successfully, except it moves in the negative direction for positive moves.

Do you have any suggestions on how to make this work?

Thanks,
Hugh


On Tue, Oct 1, 2013 at 6:04 PM, TK <tk@...> wrote:
 

Hi Hugh,

All good questions. Yes the commutation is based on the Encoder Position so arbitrarily changing the position. The Zero() command should zero the Position and the Destination and automatically adjust the commutation offset to keep the commutation the same. 

There are many possible strategies to homing slaved axes.  Probably the best is to jog both through the indexes and capture where they are. The stop both. Then move both to where they were detected. Then Zero both. Then Slave them together. 

HTH
Regards

TK

On Oct 1, 2013, at 12:39 PM, Hugh Sontag <hsontag@...> wrote:

 

Hi Tom,

I'm trying to understand what to do to home my CNC router with brushless DC motors.

First, I suspect that the current position is used to determine when to commutate the motor. This suggests to me that there is a potential issue with exactly what is done when the limit switch is detected.

At startup, I plan to find the index pulse on the encoder first. Then, presumably, I can enable the axis and Jog at a slow speed toward the home/negative limit switch.

But once the home switch is detected, what should be done? If "Zero()" is called, it resets the Position and Destination for the axis, but won't that cause commutation to not work?

Does "EnableAxisDest(0,0.0f)" set Position or just Destination? In other words, does a call to "EnableAxisDest(0,0.0f);" cause the axis to move to the new destination if the current position does not match the destination set by "EnableAxisDest(0,0.0f);" ?

Finally, the plot thickens when moving the X axis gantry, because it is driven by two motors.

I presume that I should find the index pulse for each motor by moving both motors simultaneously, so that the gantry moves along its track driven on both sides.

I can find the index pulse for each motor, but they won't be at the exact same place as the gantry moves. 

When one index pulse is found, I can set Position and Destination to be the same, for that motor only. Is this what I should do?

When the second index pulse is found, I can set Position and Destination to be zero for that motor.

Note that the Position and Destination won't be the same for the two axes. Is that OK, since one axis is slaved to the other?

Now both index pulses are found. Presumably, I can then set one axis to slave to the other, and Jog toward the home switch. But when I get there, I believe that I shouldn't Zero() the axes, because that will change the commutation of the motors. Is that correct?

Thanks for your help,
Hugh



  @@attachment@@
Group: DynoMotion Message: 8441 From: Tom Kerekes Date: 10/2/2013
Subject: Re: Homing with BLDC motors [1 Attachment]
Hi Hugh,

I think you need to change the sign of:

ch2->invDistPerCycle= -1.0 / 2048.0;

to

ch2->invDistPerCycle= 1.0 / 2048.0;

As shown by the AutoPhaseFind report.

Otherwise the commutation is correct until we move and the commutation angle moves the wrong way.

There is an AutoPhaseFindFast.c included with the installation.  I don't think the "slow" one is detecting the index marks reliably.  When working correctly the deltas (absolute values) from 0-2, 1-2, 2-3 should all be the same

HTH
Regards
TK

Group: DynoMotion Message: 8442 From: Hugh Sontag Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Hi Tom,

I changed the invDistPerCycle to +1/2048, but with the change, the SnapAmp faults as soon as the axis is enabled.

Previously, it didn't fault until I made an attempt to move the Y axis with a Step Response test.

Hugh


On Wed, Oct 2, 2013 at 5:09 PM, Tom Kerekes <tk@...> wrote:
 

Hi Hugh,

I think you need to change the sign of:

ch2->invDistPerCycle= -1.0 / 2048.0;

to

ch2->invDistPerCycle= 1.0 / 2048.0;

As shown by the AutoPhaseFind report.

Otherwise the commutation is correct until we move and the commutation angle moves the wrong way.

There is an AutoPhaseFindFast.c included with the installation.  I don't think the "slow" one is detecting the index marks reliably.  When working correctly the deltas (absolute values) from 0-2, 1-2, 2-3 should all be the same

HTH
Regards
TK

Group: DynoMotion Message: 8443 From: Tom Kerekes Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Hi Hugh,

Oh man, this is fighting us tooth and nail.  :}

Now try that with commutation offset of +398 (which is about the same thing AutoPhase find was originally telling us 398+2048=2446)

Regards
TK

Group: DynoMotion Message: 8444 From: Hugh Sontag Date: 10/2/2013
Subject: Re: Homing with BLDC motors
Changing InputGain0 = -1, invDistPerCycle = +1 / 2048 and setting CommutationOffset = +398 works, with a Step Response that looks essentially identical to the behavior with the InputGain = +1.

I am sure I don't understand this yet. Earlier, you suggested - 398, which is an offset of 1024 from the commutation offset of -1422:

"But anyways if you take the Commutation offset that worked before you reversed the encoder and add or subtract a half cycle (1024) that should work. So try -398"

I also ran "AutoPhaseFindFast.c" on the Y axis and got these results:

REPORT FOR Y AXIS
----------------
0 Position =  24578 PhaseAngle = 11.980000
1 Position =  32770 PhaseAngle = 15.979600
2 Position =  32770 PhaseAngle = 15.908800
3 Position =  24578 PhaseAngle = 11.896000
Counts per rev =   8192
Counts per cycle =   2048
Counts per cycle (not rounded)=   2048
invDistPerCycle (not rounded)=  0.000488232422
Commutation offset =   2446
Input Gain Specified = -1.000

REPORT FOR Y AXIS
----------------
0 Position =  -7992 PhaseAngle = 3.978600
1 Position = -24377 PhaseAngle = 11.983400
2 Position = -24376 PhaseAngle = 11.911000
3 Position =  -7992 PhaseAngle = 3.895000
Counts per rev = -16385
Counts per cycle =  -2047
Counts per cycle (not rounded)=  -2047
invDistPerCycle (not rounded)= -0.000488544400
Commutation offset =  -1427
Input Gain Specified =  1.000

The -1427 matches what I got earlier with "AutoPhaseFind.c". The 2446 matches your number of 398 minus 2048, but I'm not clear on how -1427 and 398 are 180 degrees apart.

Hugh

On Wed, Oct 2, 2013 at 6:01 PM, Tom Kerekes <tk@...> wrote:
 

Hi Hugh,

Oh man, this is fighting us tooth and nail.  :}

Now try that with commutation offset of +398 (which is about the same thing AutoPhase find was originally telling us 398+2048=2446)

Regards
TK